WHAT IS CLAIMED IS: 



\l . A computer program product for performing format conversions, tangibly 
stored o\a computer-readable medium, comprising instructions operable to cause a 
programmable processor to: 

identify a first representation of a persistent object and first format indicator 
associated witftythe persistent object; 

identify aVurrent format indicator; 

apply a conversion engine, wherein the conversion engine takes as inputs a first 
schema referenced byihe first format indicator, a second schema referenced by the 
current format indicator and the first representation of the persistent object and wherein 
the conversion engine generates a second representation in a format referenced by the 
current format indicator; and \ 

read the second representation to recreate the persistent object. 

2. The computer program product of claim 1, wherein the format indicators 
are format numbers. \ 

3 . The computer program product of claim 1 , wherein the schema are 
contained in a secondary program controlled by a primary program. 

4. The computer program product of claim 3, wherein the secondary program 
is a plug-in and the primary program is an applicatiorWogram associated with the plug- 
in. \ 

5. The computer program product of claim 1, wherein the conversion engine 
cooperates with a second conversion engine capable of convening formats without 
reference to the schema. \ 

6. The computer program product of claim 5, wherein Ihe conversion engines 
are part of a single conversion service contained in a single application program. 



16 



10 



7.\ A file conversion system, comprising: 
a primary program; 
a secondary program called by the primary program; 
at leastVme file associated with the primary program, the at least one file 
including a first representation of a persistent object created by the secondary program; 
a conversion service contained in the primary program; 

a set of schemas contained in the secondary program, the schemas describing the 
format in which prevWs versions of the secondary program wrote data into the at least 
one file and the formatun which the current version of the secondary program writes data; 

wherein the conversion service is capable of converting the first representation of 
a persistent object from a first format to a second format based on the format information 
provided by the set of schemas. 
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8. The system of claim 7, wherein the secondary program is a plug-in. 
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9. The system of claim JL wherein the conversion service cooperates with a 
second conversion service capable of Converting data from one format to another without 
reference to the schema. 

10. The system of claim 9, whekein the conversion services are part of a single 
hybrid conversion service contained in a single application program. 



11. A method for performing format Conversions, comprising: 
25 finding a first representation of a persisten\object and first format indicator 

associated with the persistent object; 

finding a current format indicator; 

applying a conversion engine, wherein the conversion engine takes as inputs a 
first schema referenced by the first format indicator, a secbnd schema referenced by the 
30 current format indicator and the first representation of the persistent object and wherein 
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1 3 . TheNmethod of claim 1 1 , wherein the schema are contained in a secondary 
program controlled by a primary program. 



12. \ The method of claim 11, wherein the format indicators are format 
numbers. \ 



14. The mfethad of claim 13, wherein the secondary program is a plug-in and 
the primary program is an application program associated with the plug-in. 

15. The method of claim 11, wherein the conversion engine cooperates with a 
1 5 second conversion engine capable, of converting formats without reference to the schema. 

16. The method of claim ro, wherein the conversion engines are part of a 
single conversion service contained in asingle application program. 

20 1 7. A method for performing format conversions, comprising: 

a) read a file comprising a plurality of persistent objects written by one or 
more secondary programs; \ 

b) identify a current format indicator Associated with a format compatible 
with a current version of a secondary program; \ 

25 c) identify a first format indicator associated with a first object created by a 

version of the secondary program; \ 

d) compare the format indicators to determine^vhether the persistent object is 
in a format compatible within the current version of the secondary program; 



30 conversion engine in a primary program to convert the data of thfe persistent object to a 



e) 



where the format of the persistent object is not Compatible, apply a 
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compatible format based upon format information that is associated with the format 
indicators and contained within the secondary program; 

f) \ identify another format indicator associated with another object; and 

g) \epeat steps (d)-(f) to convert the remaining persistent objects to formats 
compatible with th^current versions of the secondary programs. 

18. A method^for performing reverse format conversions, comprising: 
finding a current format indicator; 

querying a conversion service associated with a secondary program to identify a 
target format indicator associated wi^h a format in which a previous version of the 
secondary program writes data; 

applying a conversion engine in a pHmary program associated with the secondary 
program, wherein the conversion engine takes as inputs i) current and target schema 
referenced by the format indicators and stored witftin the secondary program and ii) a 
first representation of a persistent object, 

whereby the conversion engine generates a seconcKrepresentation of the persistent 
object in a format referenced by the target format indicator. 
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